|
In computer science, a fixed-point combinator (or fixpoint combinator) is a higher-order function ''y'' that satisfies the equation, : It is so named because, by setting , it represents a solution to the fixed point equation, : A ''fixed point'' of a function ''f'' is a value that doesn't change under the application of the function ''f''. Consider the function . The values 0 and 1 are fixed points of this function, because and . This function has no other fixed points. A fixed point combinator need not exist for all functions. Also if ''f'' is a function of more than 1 parameter, the fixed point of the function need not be a total function. Functions that satisfy the equation for ''y'' expand as, : A particular implementation of ''y'' is Curry's paradoxical combinator ''Y'', represented in lambda calculus by, : This combinator may be used in implementing Curry's paradox. The heart of Curry's paradox is that untyped lambda calculus is unsound as a deductive system, and the ''Y'' combinator demonstrates that by allowing an anonymous expression to represent zero, or even many values. This is inconsistent in mathematical logic. Applied to a function with one variable the ''Y'' combinator usually does not terminate. More interesting results are obtained by applying the ''Y'' combinator to functions of two or more variables. The second variable may be used as a counter, or index. The resulting function behaves like a ''while'' or a ''for'' loop in an imperative language. Used in this way the ''Y'' combinator implements simple recursion. In the lambda calculus it is not possible to refer to the definition of a function in a function body. Recursion may only be achieved by passing in a function as a parameter. The ''Y'' combinator demonstrates this style of programming. ==Introduction== The ''Y'' combinator is an implementation of the fixed-point combinator in lambda calculus. Fixed-point combinators may also be easily defined in other functional and imperative languages. The implementation in lambda calculus is more difficult due to limitations in lambda calculus. The fixed combinator may be used in a number of different areas, * General mathematics * Untyped lambda calculus * Typed lambda calculus * Functional programming * Imperative programming Fixed point combinators may be applied to a range of different functions, but normally will not terminate unless there is an extra parameter. Even with lazy evaluation when the function to be fixed refers to its parameter, another call to the function is invoked. The calculation never gets started. The extra parameter is needed to trigger the start of the calculation. The type of the fixed point is the return type of the function being fixed. This may be a real or a function or any other type. In the untyped lambda calculus, the function to apply the fix point combinator to may be expressed using an encoding, like Church encoding. In this case particular lambda terms (which define functions) are considered as values. "Running" (beta reducing) the fixed point combinator on the encoding gives a lambda term for the result which may then be interpreted as fixed point value. Alternately a function may be considered as a lambda term defined purely in lambda calculus. These different approaches affect how a mathematician and a programmer may regard a fixed point combinator. A lambda calculus mathematician may see the ''Y'' combinator applied to a function as being an expression satisfying the fixed point equation, and therefore a solution. In contrast a person only wanting to apply a fixed point combinator to some general programming task may see it only as a means of implementing recursion. 抄文引用元・出典: フリー百科事典『 ウィキペディア(Wikipedia)』 ■ウィキペディアで「Fixed-point combinator」の詳細全文を読む スポンサード リンク
|